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METHOD, SYSTEM, AND PROGRAM FOR CUSTOMER SERVICE 
AND SUPPORT MANAGEMENT 

Inventors : Andy Lee, Hsyh-Min Hsu, Paul Hao, Edward Shyh-Tyng Sun and Tracy 
5 Tseng. 

BACKGROUND OF THE INVENTION 

1. Field of the Invention 

The present invention relates in general to business management software, and 
10 more particularly to a web-based, integrated service and support software suite. 

2. Description of the Related Art 

Managing product logistics and customer care is often the most difficult 
aspect of business. Companies have invested huge amounts of money and resources 

1 5 to make sure their products are readily available and that their customers receive the 
best service. However, customer relations do not end with the sale of the product. 
Servicing a customer after the purchase of a good is also a major challenge to the 
manufacturer of that product. Responding to e-mail inquiries and warranty service 
requests is a labor intensive exercise often requiring huge labor support. The problem 

20 is compounded because a customer will often contact the manufacturer after the 
purchase only if something has gone wrong. Either the product is not performing 
properly or the customer has problems operating the device. Usually, such situations 
create a difficult atmosphere where the customer will often be in an impatient mood. 
Therefore, the type of experience a customer may have in contacting the manufacturer 

25 or manufacturer's representative may directly affect the manufacturer's reputation, the 
loyalty of the customer for future purchases of the manufacturer's product, and/or the 
future retail value of the product itself. 

Furthermore, managing customer service has been a difficult task because 
multiple parties are involved throughout the customer service process. The 
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manufacturer, supplier, retailer, and back-end (i.e. after purchase) service provider are 
often completely separate and independent organizations. For example, 
manufacturers will often outsource the call handling process to a third party call 
center, independent from the manufacturer. If the customer service center needs to 
5 order a replacement product or order warranty/repair work, the customer service 
center would have to go outside its organization to perform the work. Therefore, the 
managing of the process has been a difficult task for the manufacturer and its third 
party vendors. 

Systems in the prior art have attempted to create business solutions by 
1 0 computerizing parts of the process. Complex and expensive Enterprise Resource 
Planning ("ERP") software has been used by large scale manufacturers to control the 
inventory and supply chain. In addition, various call tracking software have been 
created to assist operators in correctly taking down information from the customer. In 
addition, client/customer management software have been created to keep track of 
15 contact information and customer purchases. Moreover, a existing warehouse or 
repair facility software would track the product through the repair process, to identify 
the location and estimated dates relevant to the product. However, the existing 
business tools are often not compatible with each other, causing redundancy and 
implementation problems. Moreover, because each business tool requires a separate 
20 software license, for a small or medium size business, the existing tools are often cost 
prohibitive. 

Accordingly, there is a need in the art for an improved business management 
system that addresses the concerns of the providing back-end services for 
manufacturers and retailers, their customers, and their third party vendors. 
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SUMMARY OF THE PREFERRED EMBODIMENTS 
The preferred embodiments provide a computerized system, method, and 
program for providing a multi-functional customer and product management tool over 
a common network, such as the Internet, available to various parties such as the 

5 client/manufacturer, repair facility, call center, and the warehouse. To this end, a 
common customer record for each customer is generated in a database which can be 
updated to include information such as customer contact and purchase history 
information. In addition, a common product record for each product is generated in a 
database which can be updated to include information such as general product and 

1 0 warehouse inventory information. Both the customer and product records are then 
made available to a user depending on the functionality of the management tool 
chosen by the user. In addition, the management tool allows the user depending on 
the chosen functionality of the management tool to update customer and product 
information. Moreover, the management tool keeps track of all additions and 

1 5 modifications to customer and product information to provide better customer support 
and error detection. In addition, the preferred embodiments of the management tool 
provide a back-end e-commerce solution to process and control all aspects of the 
purchase and shipping process. Lastly, the preferred embodiments of the 
management tool is able to act as a decision support system by providing reports to 

20 assist managers in making executive decisions. 

BRTEF DESCRIPTION OF THE DRAWINGS 
Referring now to the drawings in which like reference numbers represent 
corresponding parts throughout: 
25 FIG. 1 illustrates a network computing environment in which preferred 

embodiments are implemented; 

FIG. 2 illustrates a computing environment of a server in accordance with 
preferred embodiments of the present invention; 
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FIG. 3 illustrates files in records in accordance with preferred embodiments of 
the present invention; 

FIG. 4 illustrates the components of the management tool implemented to 
perform the present invention; 
5 FIG. 5 illustrates a program flow implemented in the server to provide 

customer and product information for the Customer Interaction Module; 

FIG. 6 illustrates the program flow implemented in the server to administer 
the Return Merchandise Management and the Warranty Administration modules in 
accordance with preferred embodiments of the present invention; 
10 FIG. 7 illustrates a program flow implemented in the server to administer the 

E-mail module to categorize and respond to e-mails from customers in accordance 
with preferred embodiments of the present invention; 

FIG. 8 illustrates a program flow implemented in the server to administer the 
Inventory Management module in accordance with preferred embodiments of the 
15 present invention; 

FIG. 9 illustrates a program flow implemented in the server to administer the 
Reporting System module in accordance with preferred embodiments of the present 
invention; and 

FIGs.10-22 illustrate examples of HTML pages that are implemented as part 
20 of the graphical user interface. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 
In the following description, reference is made to the accompanying drawings 
which form a part hereof and which illustrate the preferred embodiment of the present 
25 invention. It is understood that other embodiments may be utilized and structural and 
operational changes may be made without departing from the scope of the present 
invention. 

FIG. 1 is a schematic overview diagram of the network computing 
environment in which the preferred embodiments are implemented. In preferred 
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embodiments, a server 10 is linked to a customer computer 15, a manufacturer/client 
computer 20, repair facility computer 30, call center computer 40, and a warehouse 
computer 45 (collectively "user computers") using a network 50, such as the Internet. 
The network 50 may be comprised of any network system known in the art including 

5 TCP/IP based networks (e.g., an Intranet, the Internet), LAN, Ethernet, WAN, Token 
Ring, etc. Alternatively, there may be separate and different networks between the 
components. Further, there can be numerous customer, manufacturer/client, repair 
facilities, call center, and warehouse computers, however a single computer 15, 20, 
30, 40, and 45 for each category of user is used for illustration purposes. 

10 FIG. 2 illustrates software components in the server 10 in which preferred 

embodiments are implemented, including a Customer and Product Management Tool 
5, a Hypertext Transfer Protocol (HTTP) server 52, database 60, database interface 70 
and templates 72, 74, and 76. The HTTP server 52 responds to requests from the user 
computers 15, 20, 30, 40, and 45 using HTTP client programs, such as web browser 

15 programs known in the art. Upon accessing the server 52 through the network 50 
using a unique network address, such as an IP address, the management tool 5 will 
give specific access to the various modules in the management tool 5, depending on 
the secured identification provided by the user computers 1 5, 20, 30, 40, and 45. The 
management tool 5 works in conjunction with the database interface 70 to retrieve 

20 and store data in database 60 to coordinate the various customer and product 
management processes. The management tool 5 and its specific modules will be 
discussed in more detail below with respect to Fig. 4. 

The database 60 provides the customer, manufacturer/client, repair facility, 
call center and the warehouse with a central location to store and retrieve current, 

25 accurate information for varying parts of the client/product management process. The 
database 60 comprises a database program known in the art, such as a relational 
database program. In the preferred embodiments, the database 60 includes three 
database tables 61, 63, and 65. Database table 61 includes records 62a, b, .... n, 
which are used in the preferred embodiment as customer records 62a, b, ... n to store 
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information about the customer. Similarly, database table 63 includes records 64a, b, 
.... n, which are used in the preferred embodiment as user records 64a, b, ... n to store 
information about the various users of the client/product management software, and 
finally, database table 65 includes records 66a, b, .... n, which are used in the 
5 preferred embodiment as product records 66a, b, ... n to store information about the 
various products. 

The database interface 70 may comprise a Common Gateway Interface (CGI) 
program, a Java servlet, or other web page implementation known in the art to present 
the information in database 60 in a presentable format (e.g. HTML page, etc.). In 

1 0 preferred embodiments, the database interface 70 uses a secured login/password 
verification for identifying the individual customer 15, manufacturer/client 20, repair 
facility 30, call center 40, and warehouse 45 computers contacting the HTTP server 
52. The individual users login/password are compared with the login/password stored 
in the user record table 63 to verify the identity of the user. The unique identification 

1 5 will allow the database interface 70 to identify which parts of the customer or product 
records 62a, b, ... n or 66a, b, ... n are accessible by the requesting party and will 
appropriately give read/write capabilities to the customer or product records 62a, b, ... 
n or 66a, b, ...n. For example, the secured login id for a call support representative 
("CSR") will give the access to the customer information records, warranty 

20 administration records, etc., but not to the inventory management records. In 
addition, the accessed user records 64a, b, ... n will have associated information 
pertinent to the user. Additional details of the particular records available to each 
party will be discussed below in conjunction with the specific modules that are part of 
the preferred embodiment. 

25 The server 10 further stores a display template 72, an input template 74, and a 

report template 76 which are preferably implemented in a document in which 
dynamic content may be generated (i.e. HTML, Extended Markup Language (XML) 
Document, etc.). Differing variations of the display template 72, input template 74 
and report template 76 exist for the users, depending on the information to be 
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displayed or inputted, but a single display template 72, input template 74, and report 
template 76 are used for illustration purposes in FIG. 2. The display template 72 is 
used to provide the user computers 15, 20, 30, 40, 45 with customer and/or product 
information from the database tables 61 and 63. The database interface 70 generates 

5 data into the display template 72 from one or more of the records 62a, b, ... n and/or 
66a, b, ... n in the database 60. The input template 74 includes fields in which the 
user computers 15, 20, 30, 40, 45 may enter information on the customer/management 
process and used to update one or more records 62a, b, ... n and/or 66a, b, ... n in the 
database 60. Lastly, the report template 76 is used to generate various reports based 

10 on the information stored in one or more of the records 62a, b, ... n and/or 66a, b, ... n. 

The database 60, display template 72, input template 74, and report template 
76 are preferably stored in a non-volatile storage system, such as one or more hard 
disk drives, used by the server 10 for storage. The server 10 may load data from the 
storage system into volatile memory (not shown) when processing. 

15 The server 10 or the user computers 15, 20, 30, 40, 45 may comprise any type 

of computer device known in the art, including server, personal computer, mainframe, 
workstation, hand held device, etc. Moreover, the server 10 may comprise one or 
more separate computer systems to run the different program components 52, 60, and 
70. 

20 FIG. 3 provides an implementation of the fields in the customer records 62a, 

b, ... n, which include: 

Record ID 110 : Provides a unique identifier generated by the database 
interface 70 for each customer. 

Customer ID Information 112 : Comprises one or more sub-fields indicating 
25 the name, customer id #, address, telephone, and other contact information of 

the user. 

Purchase Info 114 : Comprises one or more sub-fields providing purchasing 
history about the customer including the serial #s, model names, parts 
requests, and dates of all products purchased by the customer. 
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Call History 116 : Comprises one or more sub-fields providing contact history 
of customer contact including all calls, e-mails or letters from the customer. 
Customer Modification History 118 : Comprises one or more sub-fields 
indicating any change to the customer record including modifier's name, date, 
etc. 

Return Information 120 : Comprises one or more sub-fields indicating any 
products being returned, return merchandise account #s ("RMA")(the number 
assigned to track the returned merchandise), problem codes, and various dates 
(e.g. RMA issue date, shipped date, received date, etc.). 
Credit Card Information 122 : Comprises one or more sub-fields indicating the 
customer's card name, card number, expiration date, billing address, etc. 
E-mail correspondance 124 : Provides a log of all e-mail received and sent to 
the customer. 

Warranty Information 126 : Comprises one or more sub-fields recording 
warranty information including any extended warranty purchased, warranty 
expiration dates, etc. 

Shipping Information 128 : Comprises one or more sub-fields recording the 
shipping information selected by the customer after the purchase of a product 
including the tracking information on the delivery of the product to the 
customer including method of shipment, carrier, date of shipment and 
estimated time of arrival ("ETA"). 

FIG. 3 also provides an implementation of the fields in the user records 64a, b, ... n of 
the preferred embodiments, which include: 

Record ID 140 : Provides a unique identifier generated by the database 

interface 70 for each user. 

User ID Information 142 : Stores a unique username and password that 
identifies the user, and allows the user to login and access specific customer 
and/or product information. 
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Problem Codes 144 : Provides codes specific to the user to identify 

problems/issues expected to be encountered by the user. 

Resolution Codes 146 : Provides codes specific to the user to identify 

solutions/conclusions expected to be derived by the user. 

E-mail Templates 148 : Provides basic templates to respond to e-mail based on 

problem codes. 

FIG. 3 also provides an implementation of the fields in the product records 66a, b, ... 
n of the preferred embodiments, which include: 

Record ID 150 : Provides a unique identifier generated by the database 

interface 70 for each product. 

Product Information 152 : Comprises one or more sub-fields indicating the 
product name, product id #, description, etc. 

Location 154 : Indicates the location of products currently available at the 
warehouse, supplier, and/or the store. 

Quantity 156 : Indicates the number of products currently available at the 
warehouse, supplier, and/or the store. 

Order Information 158 : One or more sub-fields set by the database interface 

70 indicating the pull status (i.e. status of the products being pulled from the 

warehouse to the store or to be sent to the customer) and order status (i.e. 

status of the products being ordered from supplier). 

Invoice Information 160 : Comprises one or more sub-fields indicating the 

price, shipping fee, coupon information, etc. associated with the products. 

Low-Level Indicator 162 : Provides the preset number of products left in 

inventory before the notice of low-level is sent. 

Product Modification History 164 : Comprises one or more sub-fields 

indicating any change to the product record including modifier's name, date, 

etc. 
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Those skilled in the art will appreciate that FIG. 3 is a preferred embodiment of the 
record 62 a, b, ... n, 64 a, b, ... n, and 66 a, b, ...n, but not as the only implementation. 
The records 62, 64, and 66 can be structured in many alternative formats to 
accomplish the present invention. For example, the separate Location 154 and 
5 Quantity 1 5 6 fields may not be needed and instead a single field may be used to 
indicate both the location and quantity. Another example is the problem codes 144 
resolution codes 146, and e-mail templates 148 in the user record 64 do not need to be 
associated with directly with the user record 64, but instead stored on the server 10 
apart from the database 60. Thus, the database tables 61, 63, and 65 can be structured 
1 0 in many alternative formats to accomplish the present invention. 

The management tool 5 of the present invention is an integrated customer and 
product management solution performing various tasks through different modules in 
the management tool 5. FIG. 4 gives an overview of the management tool 5 as it 
integrates the various modules 220, 230, 240, 250, 260, 270, and 280 through linked 
1 5 directories of pages that may be navigated using an Internet browser, e.g., Microsoft 
Internet Explorer, Netscape Communicator, etc. The FIG. 4 illustrates the 
components of the management tool 5, including a browser program 200, such as a 
web based browser or other viewing program known in the art, a main page 210 that 
provides an index to the other modules, including hyperlinks 215 to the actual 
20 modules 220, 230, 240, 250, 260, 270, and 280. The terms hypertext link and 
hyperlinks are used interchangeably herein to refer to an element in an electronic 
document that links to another place in the same document or to an entirely different 
document. Typically, a user clicks on the hyperlink to follow the link. Modules 
included in the management tool 5 are a Customer Interaction Module 220, a Return 
25 Merchandise Management module 230, an E-mail Management module 240, a 
Warranty Administration Module 250, a Credit Card Processing Module 260, an 
Inventory Management Module 270, and a Reporting System module 280. In the 
described implementations, the main page 210 provides hyperlinks 215 to one or 
more of the modules 220, 230, 240, 250, 260, 270, and 280, each comprised of 
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multiple linked text plan pages which provide pertinent features and information 
relevant to the module using the common data stored in database 60. Each module 
will be discussed in greater detail with respect to FIGs. 5-9. 

FIGs. 5, 6, 7, 8, and 9 illustrate the program logic embedded in the 

5 management tool 5, HTTP server 52, and database interface 70 to implement the 
customer and product management processes of the preferred embodiments. In 
addition, FIGs. 10-20 will be discussed alongside the program logic to illustrate 
examples of HTML page implementations of various pages within the modules 220, 
230, 240, 250, 260, 270, and 280 accessible through browser 200. 

10 FIG. 5 illustrates the program logic to provide customer record 62a, b,...n and 

product record 66a, b, ... n information for the customer interaction module 220. 
Typically, the customer interaction module 220 begins with a phone call from the 
customer to the call center. The customer interaction module 220 allows the customer 
service representative (CSR) to maintain and log customer records for customers that 

1 5 call in for technical support, or customer service, such as purchase or information 
requests, e.g. status on a particular order. A CSR, who has already logged into the 
customer interaction module 220 via a secured identification and password, will 
handle the call and attempt to access the customer's information via the secured 
network 50. At block 500, the HTTP server 52 receives a request from the call center 

20 computer 40 for information on a customer record 62a, b, ... or n. At block 502, a 
determination is made by the database interface 70 on whether the customer record 
exists. The database interface 70 can search for the customer record 62a, b, ... or n 
using the customer name, phone number, serial number, RMA number, or part request 
number looking at Customer ID Information 1 12, Purchase Info 1 14, and Return Info 

25 120 Fields of the customer records 62a, b, ... n. If no existing customer record is 
found, the customer interaction module 220 will give the option to add a new 
customer record. To create a new customer record 62a, b, ... or n, the database 
interface 70 (at block 504) accesses the input template 74 and builds an HTML web 
page. At block 506, the built HTML input page is then sent to the call center 



1 ~ Express Mail No. 82 1 1 57442US 

Firm No. 0075.0001 

computer 40, where the CSR can enter customer information such as name, address, 
phone number, e-mail, etc. The HTTP server 52 then receives the HTML input page 
with the customer information entered by the CSR. In response, the HTTP server 52 
requests the database interface 70 to create a new customer record 62a, b, ... or n, and 

5 fill in the customer id info field 1 1 2 of the new record with the information inputted 
by the CSR, as well as keep track of the creation of the record 62 a, b, ... or n in the 
customer modification history field 118. The customer modification history field 118 
will keep track of user name, date, description of changes, and any additional 
comments related to any modification in the customer record 62a, b, ... or n. 

10 Whether a new record 62 a, b, ... or n is created or an existing customer record 

62a, b, ... or n is found, the database interface 70 (at block 508) accesses the display 
template 72 and builds an HTML web page. The database interface program 70 
queries (at block 510) the database table 61 for the requested or newly created record 
62a, b, ... or n and then inserts (at block 512) the returned information into the display 

1 5 template. The database interface 70 will then build one or more linked HTML web 
pages based on a display template 72 which will list a menu of information available 
to the CSR such as customer info, purchase history, customer service history, 
warranty and extended service agreement information, return information, part 
request information, credit card information, etc. Thus, the generated display pages 

20 can include information from such fields as Customer ID Info 1 12, Purchase Info 1 14, 
Call History 1 16, Customer Modification History 118, Return Info 120, Credit Card 
Info 122, E-mail Correspondence 124, Warranty Info 126, and Shipping Info 128. 

Once the relevant customer record 62a, b, ... or n is displayed, where an 
example of the customer record is shown in FIG. 10, the CSR at block 514 can make 

25 modifications to the customer information if the contact information needs to be 
changed. To update a customer record 62a, b, ... or n, at block 518, the CSR can just 
change and enter the new customer information such as name, address, phone 
number, e-mail, etc. In response, the HTTP server 52 requests the database interface 
70 to update the customer id info field 112 with the new information and record the 
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change in the customer modification history field 118 of the specific customer record 
62a, b, ... or n. Similarly, at block 514, the CSR can also change the product 
information, where the purchase info 1 14 and the customer modification history 118 
fields will be updated at block 526. At block 520, if the relevant product which the 
5 customer is calling about is not listed, the CSR can add a new product under the 
customer's record, as illustrated in FIG. 1 1 A. To add new product information, the 
database interface 70 (at block 524) accesses the input template 74 and builds an 
HTML web page. At block 526, the built HTML input page is then sent to the call 
center computer 40, where the CSR can enter the product information such as product 
10 name, model number, serial number, purchase date, etc. as seen in FIG. 1 IB. The 
HTTP server 52 then receives the HTML input page with the purchase information 
entered by the CSR. In response, the HTTP server 52 requests the database interface 
70 to update the purchase info 1 14 and the customer modification history 118 fields, 
and the updated customer record 62a, b, ... n will be redisplayed in one or more linked 
1 5 display pages at block 512. 

If the relevant product information is listed as seen in FIG. 1 1, the CSR can 
then select the create ticket page since each customer interaction has to be tracked 
before it is terminated. An example of the Create Ticket Page is seen in FIG. 12. At 
block 528, the CSR can select a call issue or problem code from the list of problem 
20 codes likely to be encountered by the CSR from the list stored in Problem Codes 144 
field associated with the user, and create a ticket. In the preferred embodiments, the 
CSR, at block 530, then fills out a note field explaining the reason for the call and the 
resolution for the call, as well as selecting a resolution code from the list stored in the 
Resolution Codes 146 field associated with the user. The codes are completely 
25 customizable and can include "Resolved Inquiry," "Processed Sale," "Issued RMA," 
"No Action," "Reported Complaint," for customer service/returns issues or 
product/part codes directly such as "Modem," "HDD," "Motherboard", etc. 
Depending on the solution, the CSR can then enter the Return Merchandise 
Management 230 (at block 532), the Warranty Administration 250 (at block 536), 
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Credit Card Processing (at block 538) modules, or simply give the customer 
information (at block 534). 

FIG. 6 illustrates the program logic implemented in the HTTP server 52 and 
database interface 70 to administer the Return Merchandise Management 230 and the 

5 Warranty Administration 250 modules. The modules 230 and 250 can be accessed by 
the CSR from the customer interaction module 220 for informational purposes or to 
issue an RMA by selecting the RMA information page. In addition, the repair facility 
30 can access the modules 230 or 250 to update the repair process and/or check on the 
warranty status. As in the logic of FIG. 5, the repair facility 30 can search for the 

1 0 specific product or customer information by searching the database for the customer 
record 62 a, b, ... or n as illustrated in FIG. 13 A and FIG. 15 A. At block 600, the 
HTTP server 52 receives a request from the call center 20 or repair facility 30 
computers to access the Return Merchandise Management 230 or Warranty 
Administration 250 modules. In response, the HTTP server 52 requests (at block 

15 602) the database interface 70 to access the display template 72 and build (at block 
604) one or more HTML display pages by querying the return info 120 or warranty 
info 126 fields for the specified customer record 62a, b, ... n. At block 606, the built 
HTML display pages are then sent to the call center 20 or repair facility 30 computers, 
where the user can view and edit the RMA and/or warranty information associated 

20 with the customer record 62a, b, ... or n. 

Once a customer's information along with the RMA or Warranty information 
are displayed (on separate pages as seen in FIGs. 14 and 15), additions or 
modifications can be made to the return info 120 or warranty info 126 fields of the 
customer record 62a, b, ... n. A CSR will access the Return Merchandise 

25 Management module 230 in order to issue a RMA number to facilitate a return of a 
defective product. Similarly, a CSR will access the Warranty Administration Module 
250 in order to administer warranty information as well as administer extended 
warranty and service plan specifics, such as the effective date for honoring reasons, 
warranty type or service plan, term and price. A repair facility will typically only 
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access the return merchandise management module 230 to update the status of each 
returned product as it travels through all the operational stages of the repair lifecycle 
in the repair center. However, the repair personnel can also query each product's 
RMA info and/or warranty info for informational purposes. At block 608, the user 

5 can chose to add or update the return info 120 or warranty info 126 fields. The 
database interface 70 (at block 610) accesses the input template 74 and builds an 
HTML web page. At block 612, the built HTML input page is then sent to the call 
center 40 or repair facility 30 computers, where the CSR can issue an RMA by 
selecting the "Issue RMA" code or repair personnel can update the status of a returned 

1 0 product by selecting the product and adding additional information such as receiving 
info, repair stage info, quality control discrepancy results, inspection results, etc. as 
seen in FIG. 16. The HTTP server 52 then receives the HTML input page with the 
information added by the CSR or repair personnel. In response, the HTTP server 52 
requests the database interface 70 to update the return info 120 or warranty info 126 

1 5 fields as well as the customer modification history 1 1 8 field. The updated customer 
record 62a, b, ... or n will be then redisplayed in one or more linked display pages at 
block 602. 

Another unique aspect of the return merchandise management module 230 is 
the ability to implement a cost effective bar code solution for the repair facility. By 

20 using commercial bar code font to code the RMA number, the repair facility 30 can 
simply print a bar code label from the return merchandise management module 230 
and place it on the returned product. Thus, rather than having to search for the 
returned product each time the repair personnel needs to update the status of the 
returned product, the repair personnel can simply scan the bar code. Since a repair 

25 personnel is identified by a unique user id, many of the update processes can be stored 
in the resolution codes 146 of the user record 64 a, b, ... or n, and automatically used 
to update the return info field 120 for the returned product. For example, the 
receiving clerk at the repair facility by scanning in the bar code will automatically 
register the received status, received date, and receiving clerk info in the return info 
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120 and customer modification history 118 fields of the customer record 62a, b, ... or 
n. 

Another feature of the warranty administration module 250 is its ability to be 
interlinked with the Credit Card Processing Module 260. If a customer wishes to 

5 purchase an extended warranty plan or encounter a pay for support situation, the 
Credit Card Processing module 260 can access the database record 62a, b, ... or n, to 
retrieve the credit card information stored in Credit Card Info field 122. The Credit 
Card module 260 can charge or charge-back the credit card for the amount authorized 
by the customer. In addition, the credit card module 260 incorporates a universal 

10 translation bridge to be able to process the credit card through any of the major credit 
card servicers on the network 50. Moreover, as in the warranty module 250, the credit 
card processing module 260 can provide a convenient payment process with any of 
the other modules in the management tool 5. 

FIG. 7 illustrates the program logic implemented in the HTTP server 52, 

15 database interface 70, and the e-mail management module 240 to categorize and 
respond to e-mails from a customer 15. At block 700, e-mail is received from the 
customer 15. The e-mail management module 240 interfaces with an e-mail client 
program such as Microsoft Outlook and conducts a review of the e-mail's API code. 
The e-mail management module 240 looks for key words in the e-mail's API code to 

20 initially categorize the e-mails and send them to the appropriate CSR in charge of 
responding to that particular type of inquiry. For example, a warranty question will 
go to a warranty service representative. The identity of the customer will be 
ascertained by the CSR and the call history field 116 will be updated as in the logic of 
FIG. 5. At block 704, the CSR can make a confirmation of the nature of the e-mail 

25 and select from the list of problem codes and solution codes likely to be encountered 
by the CSR from the list stored in Problem Codes 144 and Resolution Codes 146 field 
associated with the user, including the ability to forward the e-mail or research the 
issues raised by the e-mail The call history field 1 16 will then be updated to record 
the selections of the CSR. The CSR, at block 706, then fills out an e-mail response 
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from the e-mail templates stored in the e-mail templates field 148 associated with the 
user record 64a, b, ... or n. Since the reply window, in the preferred embodiments as 
seen in FIG. 17, is already populated with a standard opening and closing message, by 
picking the appropriate e-mail template, the CSR can reply quickly to the e-mail by 

5 either sending out an e-mail message back to the customer, forward the e-mail to the 
manufacturer/client 20 for second-level support, send it to a research queue for further 
investigation by a senior representative, or remove it. The response will then be 
recorded by updating the e-mail correspondance field 124. In alternative 
embodiments, the e-mail management module 240 can also allow the email 

1 0 representative to create a new template and assign it a particular category for issues 
that have not occurred, but might be reoccuring at a later time. 

FIG. 8 illustrates the program logic implemented in the HTTP server 52 and 
the database interface 70 to administer the Inventory Management module 270 
according to the preferred embodiments. The inventory management module 270 is 

1 5 designed to administer the inventory in a warehouse from purchasing, carrying, 
picking, packing, and shipping of products. The module 270 provides real-time 
inventory levels, and enables product managers to manage product specs, quantities, 
promotions, and categorization. A product manager, who has already logged into the 
inventory module 270 via a secured identification and password, can manage the 

20 inventory via the secured network 50. The module 270 typically begins at block 800, 
where the HTTP server 52 receives a request from the manufacturer/client 20 or 
warehouse 45 computers for information on a product record 66a, b, ... or n. The 
database interface 70 can search for a product record 66a, b, ... or n using the product 
name, category, its specs, web-store representation, quantity on hand or by querying 

25 the database for a compatible model or substitute. The database interface 70 will 
search the Product Information 152, Location 154, and Quantity 156 fields of the 
product records 66a, b, ... n. At block 802, the database interface 70 accesses the 
display template 72 and builds an HTML web page. The database interface program 
70 queries (at block 804) the database table 65 for the requested product record 66a, 
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b, ... or n and then inserts (at block 806) the returned information into the display 
template. The database interface 70 will then build one or more linked HTML web 
pages based on a display template 72. As seen in FIG. 18, this search will bring up 
the product information GUI ("Graphical User Interface") that is designed to display 

5 all detailed specs pertaining to this product including quantities on hand in the 
warehouse, inventory records, categorization, product specs, compatible model, 
substitute product, product modification history, etc. Thus, the generated display 
pages can include information from such fields as Product Info 152, Location 154, 
Quantity 156, Order Info 158, Invoice Info 160, Low-level Indicator 162, and Product 

1 0 Modification History 1 64 fields. Depending on the information desired, the inventory 
module 270 can display the information in many forms on different pages. For 
example, FIG. 19A shows an example of a page listing only the inventory on hand 
listing the product SKU number, model name, location, and quantity. 

Once the relevant product record 66a, b, ... or n is displayed, then at block 808 

1 5 the inventory manager can make modifications to the product information if the 
product information needs to be changed, or to input information about a new 
product. To update or create a new product record 66a, b, ... or n, the database 
interface 70 (at block 812) accesses the input template 74 and builds an HTML web 
page. The user can then just change or input new product information, such as 

20 quantities on hand, product description, location, order info, etc. The product 

manager can also determine product specs, marketing information, and pictures that 
can be shown on a web-store displaying the product. The product manager can also 
categorize the product by web-store, category, sub-category, and set promotion 
standards. Thereafter, the product manager can select for compatible models and 

25 substitutes via the "Compatible Model" and "Substitute" Tabs by selecting 

compatible/substitution models and clicking the "Add" button. The product manager 
can also check for open inventory purchase orders via the "Inventory Records" Tab as 
well as set a low-level economic reorder point notification at a preferred level. In 
addition, the warehouse 45 can also click on the "Inventory" Tab to check and adjust 
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real-time inventory levels by product SKU, where the page specifies each SKU's 
warehouse location and quantity on hand. Any time a product is shipped out, the 
inventory levels are decreased by one. In response, the HTTP server 52 (at block 8 14) 
requests the database interface 70 to update one or more of following fields: the 
5 product id info 152, location 154, quantity 156, order info 158, invoice info 160, low- 
level indicator 162, and as well as record the change in the product modification 
history field 164 of the specific product record 66a, b, ... or n. The updated product 
record 66a, b, ... n will be eventually redisplayed in one or more linked display pages 
at block 802 after a several other logic inquiries (to be discussed below). 
1 0 At block 8 1 6, any time there is any adjustment in the quantity field 1 56, a 

comparison is made with regards to the quantity field 156 and the low-level indicator 
field 162. If the quantity of products on hand reaches the number set for the low- 
level indicator, a notification (at block 818) is sent to the product manager or 
warehouse personnel. The notification can initiate the reorder process, where a user 
1 5 would access the inventory module 270 and enter a purchase order for the product, 
including the vendor, unit cost, SKU, and desired quantity, as seen in FIG. 19B. The 
purchase order will be recorded in both the Order Info 158 and Product Modification 
History 164 fields as in the logic explained above with regards to modifying a product 
record 66a, b, ... or n. At block 820, an invoice option is available to register the sale 
20 of the product if there was an adjustment to the quantity field 156. Via the "Invoice" 
page, as shown in FIG. 20A, the warehouse personnel can enter or look up the 
customer's invoice information, e.g. shipping address, credit card information, 
shipping method, credit card authorization numbers, and pre-authorization dates. The 
information is populated from the customer's original input from the customer 
25 interaction module 220 and interlinked with the Credit Card Processing module 260 
to charge the purchase ticket. The Invoice page also displays the status of the order. 
Once an invoice is generated, the shipping personnel can generate a Picking Sheet, as 
seen in FIG. 20B, to determine what products should be shipped along with a copy of 
the picking sheet for the customer. Moreover, in preferred embodiments, the 
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Inventory Module 270 is integrated with third party shipping software, such as 
Airborne Express, UPS, etc. to monitor the progress of the product shipment from the 
Inventory Module 270 directly. Once the user is completed with the Inventory 
Module 270, the user can exit the module at block 826. 

5 A key aspect of the inventory management module 270 is that it can be linked 

to a front-end GUI to act as a shopping cart for e-commerce purposes. Each purchase 
by a customer computer 15 can automatically interact with the inventory module 270, 
initiating the shipping and invoicing processes. To account for each sale, the 
inventory module 270 updates the location 154, quantity 156, and invoice info 160 

10 fields of the database record 66a, b, ... or n. In addition, to provide for better 

integration of the inventory module 270 with an e-commerce shopping cart, much of 
the graphics for the front-end GUI can be stored with the relevant database record 
66a, b, ... or n, along with its descriptions, promotions, etc. In addition, the inventory 
module 270 can be interlinked with the Credit Card Processing Module 260. 

1 5 Thereby, the inventory 270 and credit card processing 260 modules can work together 
to seamlessly provide an e-commerce solution over the network 50. 

FIG. 9 illustrates the program logic implemented in the HTTP server 52 and 
database interface 70 to administer the Reporting System module 280 according to the 
preferred embodiments. The report module 280 can be accessed by the 

20 manufacturer/client 20 to report in real-time to bring the most mission critical 

operating and sales figures to executive managers. The reporting module 280 is thus 
able to aid as a decision support system to assist management in making executive 
decisions that might make the business more efficient and effective (e.g. changing the 
vendor on a product that receives a high percentage of RMAs, or changing seasonal 

25 strategies based on sales figures or customer interaction drivers). Although the type 
of report generated can be varied as the report templates 76, examples of reports can 
be seen in FIGs. 21 and 22. Typically the process of generating a report starts at 
block 900 where the HTTP server 52 receives a request from the manufacturer/client 
computer 20 to access the Reporting System module 280 from a user who has already 
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logged into the reporting module 280 using a secured identification and password via 
the secured network 50. In response, the HTTP server 52 requests (at block 902) the 
database interface 70 to access the report template 76 and build one or more HTML 
report pages. The database interface program 70 queries (at block 906) the database 
5 tables 6 1 and/or 65 for the predefined report parameters and then inserts (at block 
908) the returned information into the report template. The database interface 70 will 
then build one or more linked HTML web pages (at block 908) based on a report 
template 76 furnishing report information to the user such as Sales Report by Date 
Range, RMA report by product, Inventory Report by SKU, Parts Request by Date, 
10 Average e-mail request ratio by month, Geographical Sales Report, etc. Thus, the 
generated report pages can include information from such fields as Customer ID Info 
1 12, Purchase Info 1 14, Return Info 120, E-mail Correspondence 124, Warranty Info 
126, Shipping Info 128, Product Info 152, Location 154, Quantity 156, Order Info 
158, and Invoice Info 160. 
1 5 Those skilled in the art will appreciate that alternative embodiments exists 

from the description of the preferred embodiments without departing from the spirit 
and scope of the invention. The preferred embodiments may be implemented as a 
method, apparatus or article of manufacture using standard programming and/or 
engineering techniques to produce software, firmware, hardware, or any combination 
20 thereof. The term "article of manufacture" as used herein refers to code or logic 
implemented in hardware logic (e.g., an integrated circuit chip, Field Programmable 
Gate Array (FPGA), Application Specific Integrated Circuit (ASIC), etc.) or a 
computer readable medium (e.g., magnetic storage medium (e.g., hard disk drives, 
floppy disks,, tape, etc.), optical storage (CD-ROMs, optical disks, etc.), volatile and 
25 non-volatile memory devices (e.g., EEPROMs, ROMs, PROMs, RAMs, DRAMs, 
SRAMs, firmware, programmable logic, etc.). Code in the computer readable 
medium is accessed and executed by a processor. The code in which preferred 
embodiments of the configuration discovery tool are implemented may further be 
accessible through a transmission media or from a file server over a network. In such 
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cases, the article of manufacture in which the code is implemented may comprise a 
transmission media, such as a network transmission line, wireless transmission media, 
signals propagating through space, radio waves, infrared signals, etc. Of course, 
those skilled in the art will recognize that many modifications may be made to this 
5 configuration without departing from the scope of the present invention, and that the 
article of manufacture may comprise any information bearing medium known in the 
art. 

The described implementations utilized a web-based environment utilizing the 
Hypertext Transfer Protocol (HTTP) for transmitting documents between computers 

10 within a network. However, those skilled in the art will appreciate that the preferred 
embodiments may apply to any communication protocol for allowing a terminal to 
request and access files in a network environment. 

In addition, preferred embodiments described the customer, user, and product 
information being implemented as database records in a database table. However, the 

1 5 customer, user, or product information may be implemented in any format for 

maintaining object information, including spreadsheet, non-database table, etc. Thus, 
as used herein, the terms database record, database table, and database refer to any 
data structure known in the art for maintaining information on data objects, such as 
relational databases, non-relational databases, spreadsheets, ASCII text files, etc. 

20 In the described implementations, the pages were described as utilizing the 

Hypertext Markup Language (HTML) file format. However, alternative file formats 
for building web-like pages may be used, such as Dynamic Hypertext Mark-Up 
Language (DHTML), the Extensible Markup Language (XML), Cascading Style 
Sheets, any other Standard Generalized Markup Language (SGML), or any other 

25 language known in the art for creating interchangeable, structured documents. 

Further, any version of HTML may be used, including version 2.0, 3.2, 4.0, etc. In yet 
further implementations, the requested file may be in any other file format, i.e., other 
than an SGML type format, capable of being displayed or otherwise executed by the 
requesting terminal. 
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Therefore, the foregoing description of the preferred embodiments of the 
invention has been presented for the purposes of illustration and description. It is not 
intended to be exhaustive or to limit the invention to the precise form disclosed. 

5 Many modifications and variations are possible in light of the above teaching. It is 
intended that the scope of the invention be limited not by this detailed description, but 
rather by the claims appended hereto. The above specification, examples and data 
provide a complete description of the manufacture and use of the composition of the 
invention. Since many embodiments of the invention can be made without departing 

10 from the spirit and scope of the invention, the invention resides in the claims 
hereinafter appended. 



